function doGet() {
  return HtmlService.createHtmlOutputFromFile('Index');
}

function saveData(name, date, duration, reason, remarks) {
  const sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Submissions');
  sheet.appendRow([name, date, duration, reason, remarks]);
}

function getData() {
  const sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Submissions');
  const data = sheet.getDataRange().getValues();
  
  // Remove header row and extract data
  const header = data[0];
  const rows = data.slice(1);

  // Sort rows by date in descending order
  rows.sort((a, b) => {
    const dateA = new Date(a[1]);
    const dateB = new Date(b[1]);
    return dateB - dateA; // Sort in descending order
  });

  // Reverse the order to make the most recent entry appear at the top
  rows.reverse();

  // Format date and return the data
  const formattedData = rows.map(row => {
    const [name, date, duration, reason, remarks] = row;
    return [name, formatDate(date), duration, reason, remarks];
  });

  return formattedData;
}

function formatDate(date) {
  if (date instanceof Date) {
    return Utilities.formatDate(date, Session.getScriptTimeZone(), 'yyyy-MM-dd');
  }
  return date; // In case it's already a string
}
